﻿<html dir="ltr" xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8"></meta>
    <title>第14章 レシーバー</title>
    <link rel="stylesheet" type="text/css" href="../css/common.css"></link>
    <link rel="stylesheet" type="text/css" href="../css/screen.css" media="screen"></link>
    <link rel="stylesheet" type="text/css" href="../css/_print.css" media="print"></link>
    <link rel="stylesheet" type="text/css" href="../css/prettify.css" media="screen"></link>
  </head>
  <body dir="ltr" onload="prettyPrint(); decorate();">
    <script type="text/javascript">prefix='../';</script>
    <script type="text/javascript" src="../js/prettify.js"></script>
    <script src="../templates/header.js" type="text/javascript"></script>
    <script type="text/javascript" src="../js/dsl.js"></script>
    <script type="text/javascript" src="../js/jquery-min.js"></script>
    <script type="text/javascript" src="../js/decorator.js"></script>
    <div id="left">
      <noscript>Please turn on Javascript to view this menu</noscript>
      <script src="../templates/left.js" type="text/javascript"></script>
    </div>
    <div id="right">
      <script src="menu_ja.js" type="text/javascript"></script>
    </div>
    <div id="content">

      <h1>第14章 レシーバー</h1>

      <div class="quote">

        <p><em>岸が見えなくなることを恐れない勇気が無ければ、地平線の向こうまで泳ぎ着くことはできない。</em></p>
  
        <p>—WILLIAM FAULKNER</p>
      </div>


    <script type="text/javascript" src="../templates/creative.js"></script>
    <script type="text/javascript" src="../templates/setup.js"></script>
    
      <h2 class="doAnchor" name="whatIsAReceiver">レシーバーとは何か？</h2>
    
      <p><em>レシーバー</em>とは、リモートアペンダーからロギングイベントを受信し、ローカルポリシーに基づいてログに記録するlogbackのコンポーネントです。ソケットベースのアペンダーとレシーバーを組み合わせることで、分散アプリケーションのロギングイベントをネットワーク越しに配信する高度なトポロジーを実現することができます。</p>
  
      <p>レシーバーは<code><a href="http://logback.qos.ch/xref/ch/qos/logback/classic/net/ReceiverBase.html">ch.qos.logback.classic.net.ReceiverBase</a></code>クラスを継承しています。おかげで<a href="http://logback.qos.ch/xref/ch/qos/logback/core/spi/LifeCycle.html">LifeCycle</a>に参加できるし、レシーバー自体が<a href="http://logback.qos.ch/xref/ch/qos/logback/core/spi/ContextAware.html">ContextAware</a>になります。</p>
    
      <p>歴史的な経緯により、logback によるネットワーク越しのロギングイベントの配信は<code>SocketAppender</code>と<code>SimpleSocketServer</code>によって実現されてきました。アペンダーはクライアントとして動作します。サーバーアプリケーションへのネットワーク接続を確立し、ロギングイベントを配信するのです。レシーバーコンポーネントと対応するアペンダーを使うことで、より優れた柔軟性を実現することができます。</p>
    
      <p>レシーバーコンポーネントは他のlogbackのコンポーネントと同様に<em>logback.xml</em>で設定します。つまり、<a href="./11-onJoran.html">Joran</a>の全ての機能を利用することができるのです。さらに、複数のレシーバーコンポーネントを設定するだけで、<em>あらゆる</em>アプリケーションのリモートアペンダーからロギングイベントを受け付けることができます。</p>
    
      <p>アペンダーとレシーバー間のネットワーク接続の確立はどちら側からでも始めることができます。レシーバーはサーバーとして振る舞うことができます。つまり、クライアントたるリモートアペンダーからの接続を待ち受けることができます。レシーバーはクライアントとして振る舞うこともできます。サーバーとして振る舞うリモートアペンダーに対してネットワーク接続を確立することができるのです。アペンダーとレシーバーのそれぞれの役割とは無関係に、<em>ロギングイベントは常にアペンダーからレシーバーに送信されます</em>。</p>
    
      <p>レシーバーからアペンダーに接続できることは、特定の状況においてとても有用です。</p>
      <ul>
        <li>セキュリティ上の観点から、中央ロギングサーバーはファイアーウォールの後ろ側に配置されることが多いです。つまり、外部からの接続が許されないのです。レシーバーコンポーネントがクライアントとして振る舞うことで、中央ロギングサーバー（ファイアーウォールの内側）から対象のアプリケーション（ファイアーウォールの外側）に接続することができます。
        </li>
        <li>IDEのプラグインなどの開発者ツールに最適です。また、実行中のアプリケーションが生成するロギングイベントのストリームへのアクセスを、企業統制の仕組みによって管理するのにも適しています。伝統的に、logbackでこのような状況に対応する（たとえばlogback Beagleなど）には、宛先のアプリケーション（たとえばIDEで実行される開発者ツール）がサーバーの役割を担う必要がありました。管理が大変になることは明らかです。特に、開発者のワークステーションで実行しているツールならなおさらです。モバイルPCが一般的になってきているのも悩みの種になります。今では、それらのツールはクライアントとしてのレシーバーコンポーネントを実装すればよくなりました。手元でロギングイベントをフィルタしたり、警告を上げたり、内容を確認するには、リモートアペンダーに接続すればよいのです。
        </li>
      </ul>

      <p>logbackの設定には、サーバーあるいはクライアントのいずれかの役割を担うレシーバーコンポーネントを混在させることができます。数少ない制限として、サーバーとして振る舞うレシーバーコンポーネントはそれぞれ固有のポート番号で接続を待ち受けなければならないということと、クライアントとして振る舞うレシーバーコンポーネントはそれぞれただ1つのリモートアペンダーにしか接続してはならないということがあります。</p>
    
      <h2 class="doAnchor" name="receiverServerComponents">サーバーとして振る舞うレシーバー</h2>
    
      <p>サーバーとして振る舞うレシーバーはリモートアペンダーからの接続を待ち受けます。これはスタンドアローンの<code>SimpleSocketServer</code>アプリケーションと同じ機能です。ただし、レシーバーコンポーネントなら、<em>logback.xml</em>に設定するだけで、logback-classicモジュールを使っている<em>あらゆる{</em>\1}アプリケーションからロギングイベントを受信することができます。</p>
        
      <p>
        <img border="1" src="images/chapters/receivers/serverSocketReceiver.png">
      </p>

      <p>logbackの配布物には二つのレシーバーコンポーネントが含まれています。<code><a href="http://logback.qos.ch/xref/ch/qos/logback/classic/net/server/ServerSocketReceiver.html">ServerSocketReceiver</a></code>とそのSSL対応の<a href="http://logback.qos.ch/xref/ch/qos/logback/classic/net/server/SSLServerSocketReceiver.html"><code>SSLServerSocketReceiver</code></a>です。どちらも<code>SocketAppender</code>（あるいは<code>SSLSocketAppender</code>）からの接続を待ち受けるように設計されています。</p>
        
      <p><code>ServerSocketReceiver</code>の設定可能なプロパティは次のとおりです。</p>
    
      <table class="bodyTable striped">
        <tr>
          <th>プロパティ名</th>
          <th>型</th>
          <th>説明</th>
        </tr>
        <tr>
          <td><span class="prop" container="serverSocketReceiver">address</span></td>
          <td><code>String</code></td>
          <td>レシーバーが待ち受けるローカルネットワークインターフェイスのネットワークアドレス。このプロパティが指定されない場合、レシーバーは全てのネットワークインターフェイスで待ち受けるようになります。</td>
        </tr>
        <tr>
          <td><span class="prop" container="serverSocketReceiver">port</span></td>
          <td><code>int</code></td>
          <td>レシーバーが待ち受けるTCPのポート番号。このプロパティが指定されない場合、デフォルト値が使用されます。</td>
        </tr>
        <tr>
          <td><span class="prop" container="serverSocketReceiver">ssl</span></td>
          <td><code>SSLConfiguration</code></td>
          <td><code>SSLServerSocketReceiver</code>でのみサポートされているプロパティです。このプロパティには<a href="./15-usingSSL.html">SSLを使用する</a>で説明されているSSLの設定を指定します。</td>
        </tr>
      </table>
    
      <h3 class="doAnchor" name="usingServerSocketReceiver">ServerSocketReceiverの使い方</h3>
    
      <p>次の設定は、最小限のアペンダーとロガーの設定とともに<code>ServerSocketReceiver</code>を使用するものです。リモートアペンダーから受信したロギングイベントは、ルートロガーに渡されて、ローカルのコンソールアペンダーに配信されます。</p>
    
      <p class="example">例：基本的なServerSocketReceiverの設定（<a href="http://logback.qos.ch/xref/chapters/receivers/socket/receiver1.xml">logback-examples/src/main/java/chapters/receivers/socket/receiver1.xml</a>）</p>

      <span class="asGroovy" onclick="return asGroovy(&#39;receiver1&#39;);">Groovyとして表示</span>
  <pre id="receiver1" class="prettyprint source">&lt;configuration debug="true"&gt;

  &lt;appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"&gt;
    &lt;encoder&gt;
      &lt;pattern&gt;%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n&lt;/pattern&gt;
    &lt;/encoder&gt;
  &lt;/appender&gt;

  &lt;root level="DEBUG"&gt;
    &lt;appender-ref ref="CONSOLE" /&gt;
  &lt;/root&gt;

  &lt;receiver class="ch.qos.logback.classic.net.server.ServerSocketReceiver"&gt;
    &lt;port&gt;${port}&lt;/port&gt;
  &lt;/receiver&gt;

&lt;/configuration&gt;</pre>
  
      <p>レシーバーコンポーネントの<em>class属性</em>に指定した値によって、レシーバーのサブタイプを指定します。ここでは<code>ServerSocketReceiver</code>を指定しています。</p>
    
      <p>例として、<code>SimpleSocketServer</code>と非常によく似た機能を持ったサーバーアプリケーションを用意しました。logbackの設定ファイルへのパスをコマンドライン引数から受け取って、指定された設定ファイルを読み込みます。この例のアプリケーションは大した仕事をするわけではありませんが、<code>ServerSocketReceiver</code> （あるいは<code>SSLServerSocketReceiver</code>）は<em>どんな</em>アプリケーションからでも利用できることを覚えておきましょう。
      </p>
    
      <p>コマンドをプロンプトで<em>logback-examplesディレクトリ</em>に移動して、次のコマンドを実行しましょう。</p>
    
      <p class="source">java -Dport=6000 <a href="http://logback.qos.ch/xref/chapters/receivers/socket/ReceiverExample.html">chapters.receivers.socket.ReceiverExample</a> \ 
      src/main/java/chapters/receivers/socket/receiver1.xml</p>
  
      <p>クライアントアプリケーションで<code>SocketAppender</code>を設定して、実行中のレシーバーに接続することができます。サンプルのクライアントアプリケーションは、上記のレシーバーに接続する設定ファイルを読み込むだけのものです。クライアントアプリケーションはユーザー入力を待ちます。ユーザー入力はそのままレシーバーに中継されます。クライアントアプリケーションは次のように実行します。</p>
    
      <p class="source">java -Dhost=localhost -Dport=6000 \
      <a href="http://logback.qos.ch/xref/chapters/receivers/socket/AppenderExample.html">chapters.receivers.socket.AppenderExample </a>\
      src/main/java/chapters/receivers/socket/appender1.xml</p>
    
      <h3 class="doAnchor" name="usingSSLServerSocketReceiver">SSLServerSocketReceiverの使い方</h3>

      <p>次の設定は、前の設定とは違ってSSLに対応したレシーバーを使うものです。</p>

      <p class="example">例：基本的なSSLServerSocketReceiverの設定（<a href="http://logback.qos.ch/xref/chapters/receivers/socket/receiver2.xml">logback-examples/src/main/java/chapters/receivers/socket/receiver2.xml</a>）</p>

      <span class="asGroovy" onclick="return asGroovy(&#39;receiver2&#39;);">Groovyとして表示</span>
  <pre id="receiver2" class="prettyprint source">&lt;configuration debug="true"&gt;

  &lt;appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"&gt;
    &lt;encoder&gt;
      &lt;pattern&gt;%d{HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n&lt;/pattern&gt;
    &lt;/encoder&gt;
  &lt;/appender&gt;

  &lt;root level="DEBUG"&gt;
    &lt;appender-ref ref="CONSOLE" /&gt;
  &lt;/root&gt;

  &lt;receiver class="ch.qos.logback.classic.net.server.SSLServerSocketReceiver"&gt;
    &lt;port&gt;${port}&lt;/port&gt;
    &lt;ssl&gt;
      &lt;keyStore&gt;
        &lt;location&gt;${keystore}&lt;/location&gt;
        &lt;password&gt;${password}&lt;/password&gt;
      &lt;/keyStore&gt;
    &lt;/ssl&gt;
  &lt;/receiver&gt;

&lt;/configuration&gt;</pre>

      <p>前の<code>ServerSocketReceiver</code>を使った設定とこちらの設定で根本的に違うのは、レシーバーの<em>class属性</em>に<code>SSLServerSocketReceiver</code>が指定されていることと、<span class="prop">ssl</span>プロパティがネストされていることです。sslプロパティにはレシーバーの秘密鍵と証明書が配置されたキーストアの場所とパスワードを、変数で指定しています。sslプロパティの設定内容について詳しくは<a href="./15-usingSSL.html">SSLを使用する</a>を参照してください。</p>    
 
      <p>いくつか引数を追加して次のようにサーバーアプリケーションを実行します。</p>

      <p class="source">java -Dport=6001 \
      -Dkeystore=file:src/main/java/chapters/appenders/socket/ssl/keystore.jks \
      -Dpassword=changeit \
      chapters.receivers.socket.ReceiverExample \
      src/main/java/chapters/receivers/socket/receiver2.xml</p>
  
      <p>コマンドラインで指定したプロパティ<em>keystore</em>には、キーストアのfileから始まるURLを指定します。<a href="./15-usingSSL.html">SSLを使用する</a>でも説明していますが、クラスパス上のリソースを指定することもできます。</p>
    
      <p>このレシーバーには、クライアントアプリケーションから<code>SSLSocketAppender</code>で接続することができます。SSL対応のアペンダーを使う設定ファイルを、前の例で使用したクライアントアプリケーションから使うことができます。次のように実行します。</p>
    
      <p class="source">java -Dhost=localhost -Dport=6001 \
      -Dtruststore=file:src/main/java/chapters/appenders/socket/ssl/truststore.jks \
      -Dpassword=changeit \
      chapters.receivers.socket.AppenderExample \
      src/main/java/chapters/receivers/socket/appender2.xml</p>
    
      <p>この例では自己署名したX.509証明書を使用していますが、これを使っていいのはテストや実験的な用途だけです。<strong>本番環境では、SSL対応のアペンダーのために適切なX.509証明書を使うようにしてください</strong> 。詳細は<a href="./15-usingSSL.html">SSLを使用する</a>を参照してください。</p>
  
      <h2 class="doAnchor" name="receiverClientComponents">クライアントとして振る舞うレシーバー
</h2>
    
      <p>クライアントとして振る舞うように設定したレシーバーは、リモートアペンダーに接続します。リモートアペンダーは<code>ServerSocketAppender</code>などのサーバ型でなければなりません。</p>  
    
      <p>
        <img border="1" src="images/chapters/receivers/socketReceiver.png">
      </p>

      <p>logackの配布物にはクライアントとして振る舞うレシーバーコンポーネントが2つ含まれています。<code><a href="http://logback.qos.ch/xref/ch/qos/logback/classic/net/SocketReceiver.html">SocketReceiver</a></code>とそのSSL対応版の<a href="http://logback.qos.ch/xref/ch/qos/logback/classic/net/SSLSocketReceiver.html"><code>SSLSocketReceiver</code></a>です。どちらのレシーバーもリモートアペンダー（<code>ServerSocketAppender</code>あるいは<code>SSLServerSocketAppender</code>）に対して接続を確立するようになっています。</p>
        
      <p><code>SocketReceiver</code>の派生クラスで設定可能なプロパティは次のとおりです。</p>
    
      <table class="bodyTable striped">
        <tr>
        <th>プロパティ名</th>
        <th>型</th>
        <th>説明</th>
        </tr>
        <tr>
          <td><span class="prop" container="SocketReceiver">remoteHost</span></td>
          <td><code>String</code></td>
          <td>リモートアペンダーのホスト名またはIPアドレス。</td>
        </tr>
        <tr>
          <td><span class="prop" container="SocketReceiver">port</span></td>
          <td><code>int</code></td>
          <td>リモートアペンダーの待ち受けポート番号。</td>
        </tr> 
        <tr>
          <td><span class="prop" container="socket">reconnectionDelay</span></td>
          <td><code>int</code></td>
          <td>接続異常が発生した後で、再接続をする前に待機する時間を表す正の整数値。単位はミリ秒。デフォルト値は30000（30秒）です。
          </td>
        </tr>
        <tr>
          <td><span class="prop" container="SocketReceiver">ssl</span></td>
          <td><code>SSLConfiguration</code></td>
          <td><code>SSLSocketReceiver</code>でのみ設定可能なプロパティ。<a href="./15-usingSSL.html">SSLを使用する</a>で説明しているとおり、SSLの設定を指定します。</td>
        </tr>
      </table>
        
      <h3 class="doAnchor" name="usingSocketReceiver">SocketReceiverの使い方</h3>

      <p><code>SocketReceiver</code>の設定は<code>ServerSocketReceiver</code>の設定と非常によく似ています。これらの差は、サーバーとクライアントという真逆の役割に起因するものです。<code>SocketReceiver</code>はクライアントで、リモートアペンダはサーバーとして動作します。</p>
        
      <p class="example">例：基本的なSocketReceiverの設定（<a href="http://logback.qos.ch/xref/chapters/receivers/socket/receiver3.xml">logback-examples/src/main/java/chapters/receivers/socket/receiver3.xml</a>）</p>
      <span class="asGroovy" onclick="return asGroovy(&#39;receiver3&#39;);">Groovyとして表示</span>
  <pre id="receiver3" class="prettyprint source">&lt;configuration debug="true"&gt;
    
  &lt;appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"&gt;    
    &lt;encoder&gt;
      &lt;pattern&gt;%date %-5level [%thread] %logger - %message%n&lt;/pattern&gt;
    &lt;/encoder&gt;
  &lt;/appender&gt;

  &lt;root level="DEBUG"&gt;
    &lt;appender-ref ref="CONSOLE" /&gt;
  &lt;/root&gt;  

  &lt;receiver class="ch.qos.logback.classic.net.SocketReceiver"&gt;
    &lt;remoteHost&gt;${host}&lt;/remoteHost&gt;
    &lt;port&gt;${port}&lt;/port&gt;
    &lt;reconnectionDelay&gt;10000&lt;/reconnectionDelay&gt;
  &lt;/receiver&gt;

&lt;/configuration&gt;</pre>
        
      <p>この設定だと、logbackは<em>host</em>変数で指定されたホストの、<em>port</em>変数で指定されたポート番号で実行中の<code>ServerSocketAppender</code>へ接続します。リモートアペンダーから受け取ったロギングイベントは、手元でコンソールアペンダーに渡されます。
      </p>
   
      <p>コマンドプロンプトで<em>logback-examples</em>ディレクトリに移動して、次のコマンドを実行してみましょう。</p>

         

      <p>サンプルアプリケーションは上記の設定ファイルを読み込んだあと、リモートアペンダーからのロギングイベントを待ち受けます。リモートアペンダーが落ちているときは、定期的に<em>接続を拒否された</em>メッセージが出力されます。再接続が成功するか、アプリケーションが停止するまで、レシーバーは定期的にリモートアペンダーへの再接続を繰り返します。設定例にあるとおり、再接続の間隔は<span class="prop">reconnectionDelay</span>プロパティで指定することができます。<p class="source">java -Dhost=localhost -Dport=6000 \
      chapters.receivers.socket.ReceiverExample \
      src/main/java/chapters/receivers/socket/receiver3.xml</p>

      <p>この例のレシーバーは、前のアプリケーションのアペンダーにそのまま接続できます。アペンダー用のサンプルアプリケーションは、<code>ServerSocketAppender</code>を使った設定ファイルを読み込んでから、ユーザー入力を待ちます。ユーザー入力はアペンダーに接続してきたレシーバーに配信されます。アペンダー用のサンプルアプリケーションを実行してみましょう。</p>

      <p class="source">java -Dport=6000 \
      chapters.receivers.socket.AppenderExample \
      src/main/java/chapters/receivers/socket/appender3.xml</p>   

      <p>レシーバーが接続する前に入力したメッセージは破棄されます。わかりやすいですね。</p>

      <h3 class="doAnchor" name="usingSSLSocketReceiver">SocketSSLReceiverの使い方</h3>


      <p><code>SSLSocketReceiver</code>の設定は<code>SocketReceiver</code>の設定とほとんど変わりません。根本的に違うのは、レシーバーのclass属性の指定と、<span class="prop">ssl</span>プロパティがネストされていることです。基本的な設定を見てみましょう。</p>
   
      <p class="example">例：基本的なSSLSocketReceiverの設定（<a href="http://logback.qos.ch/xref/chapters/receivers/socket/receiver4.xml">logback-examples/src/main/java/chapters/receivers/socket/receiver4.xml</a>）</p>

      <span class="asGroovy" onclick="return asGroovy(&#39;receiver4&#39;);">Groovyとして表示</span>
  <pre id="receiver4" class="prettyprint source">&lt;configuration debug="true"&gt;

  &lt;appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender"&gt;    
    &lt;encoder&gt;
      &lt;pattern&gt;%date %-5level [%thread] %logger - %message%n&lt;/pattern&gt;
    &lt;/encoder&gt;         
  &lt;/appender&gt;

  &lt;root level="DEBUG"&gt;
    &lt;appender-ref ref="CONSOLE" /&gt;
  &lt;/root&gt;  
 
  &lt;receiver class="ch.qos.logback.classic.net.SSLSocketReceiver"&gt;
    &lt;remoteHost&gt;${host}&lt;/remoteHost&gt;
    &lt;port&gt;${port}&lt;/port&gt;
    &lt;reconnectionDelay&gt;10000&lt;/reconnectionDelay&gt;
    &lt;ssl&gt;
      &lt;trustStore&gt;
        &lt;location&gt;${truststore}&lt;/location&gt;
        &lt;password&gt;${password}&lt;/password&gt;
      &lt;/trustStore&gt;
    &lt;/ssl&gt;
  &lt;/receiver&gt;

&lt;/configuration&gt;</pre>

      <p><em>class</em>属性に<code>SSLSocketReceiver</code>を指定していること、そして、リモートアペンダーが信頼できるかどうかを検証するために使用するトラストストアの場所とパスワードを指定しているところが重要なところです。sslプロパティの設定内容について詳しくは<a href="./15-usingSSL.html">SSLを使用する</a>を参照してください。

      </p>
  
      <p>この設定をつかってレシーバーのサンプルアプリケーションを実行しましょう。</p>
  
      <p class="source">java -Dhost=localhost -Dport=6001 \
      -Dtruststore=file:src/main/java/chapters/appenders/socket/ssl/truststore.jks \
      -Dpassword=changeit \
      chapters.receivers.socket.ReceiverExample \
      src/main/java/chapters/receivers/socket/receiver4.xml</p>   
   
      <p>アプリケーションが開始すると、レシーバーは設定ファイルで指定されたリモートアペンダーに接続しようとします。まだアペンダーが実行されていないときは、定期的に"接続を拒否されました"というメッセージがログに出力されｒます。レシーバーは<span class="prop">reconnectionDelay</span>プロパティで指定した時間間隔で、アペンダーに接続できるまで、再接続を繰り返します。
      </p>
  
      <p>レシーバーが接続するアペンダーのためのサンプルアプリケーションを実行しましょう。アプリケーションが開始すると、アプリケーションはユーザー入力を待ち受けます。<code>SSLServerSocketAppender</code>はレシーバーからの接続を待ち受けつつ、接続されているレシーバーにユーザー入力をメッセージとして発生したロギングイベントを配信します。アペンダーのサンプルアプリケーションを実行しましょう。</p>

      <p class="source">java -Dport=6001 \
      -Dkeystore=file:src/main/java/chapters/appenders/socket/ssl/keystore.jks \
      -Dpassword=changeit \
      chapters.receivers.socket.AppenderExample \
      src/main/java/chapters/receivers/socket/appender4.xml</p>   

      <p>レシーバーが接続していない状態で何か入力しても、そのメッセージは単純に破棄されるだけです。</p>

      <p>繰り返しになりますが、この例では自己署名したX.509証明書を使用していますが、これはあくまでもテストだからです。<strong>本番環境においては、SSL対応のlogbackコンポーネントが自身の身元を証明するため、適切なX.509証明書を取得しなければなりません</strong>。詳しくは<a href="./15-usingSSL.html">SSLを使用する</a>を参照してください。
</p>
  
    <script src="../templates/footer.js" type="text/javascript"></script>

    </p></div>
  </body>  
</html>